～<template>
  <div>
    <div class="variables el-data-table">
      <el-table :data="variables" class="el-table--fit el-table--border">
        <el-table-column show-overflow-tooltip :label="$tc('Name')" prop="name" />
        <el-table-column show-overflow-tooltip :label="$tc('VariableName')" prop="var_name" />
        <el-table-column show-overflow-tooltip :label="$tc('DefaultValue')" prop="default_value" />
        <el-table-column
          v-if="!disableEdit"
          :label="$tc('Actions')"
          align="center"
          class-name="buttons"
          fixed="right"
          width="135"
        >
          <template v-slot="scope">
            <el-button icon="el-icon-minus" size="mini" type="danger" @click="removeVariable(scope.row)" />
            <el-button
              :disabled="!!scope.row.template"
              icon="el-icon-edit"
              size="mini"
              type="primary"
              @click="onEditClick(scope.row)"
            />
          </template>
        </el-table-column>
      </el-table>
      <div v-if="!disableEdit" class="actions">
        <el-button size="mini" type="primary" @click="onAddClick">
          {{ $t('Add') }}
        </el-button>
      </div>
      <AddVariableDialog
        :variable="variable"
        :variables="variables"
        :visible.sync="addVariableDialogVisible"
      />
    </div>
  </div>
</template>

<script>
import AddVariableDialog from './AddVariableDialog'

export default {
  name: 'Variable',
  components: {
    AddVariableDialog
  },
  props: {
    value: {
      type: [Array],
      default: () => []
    },
    disableEdit: {
      type: Boolean,
      default: false
    }
  },
  data() {
    return {
      variable: {},
      initial: false,
      addVariableDialogVisible: false
    }
  },
  computed: {
    variables: {
      get() {
        return this.value
      },
      set(val) {
        this.$emit('update:value', val)
        this.$emit('change', val)
      }
    }
  },
  watch: {
    variables: {
      handler(newVal, oldVal) {
        if (oldVal === undefined) return
        if (newVal.length > 0 || !this.initial) {
          newVal.map((item) => {
            item.default_value = item.text_default_value || item.select_default_value || undefined
          })
          this.$emit('input', newVal)
        }
        if (newVal) {
          this.initial = true
        }
      },
      immediate: true,
      deep: true
    }
  },
  methods: {
    removeVariable(variable) {
      this.variables = this.variables.filter((item) => {
        if (variable.id && item.id) {
          return item.id !== variable.id
        } else if (variable.var_name && item.var_name) {
          return item.var_name !== variable.var_name
        } else {
          return variable.name !== item.name
        }
      })
    },
    onEditClick(variable) {
      this.variable = variable
      setTimeout(() => {
        this.addVariableDialogVisible = true
      })
    },
    onAddClick() {
      this.variable = null
      setTimeout(() => {
        this.addVariableDialogVisible = true
      })
    }
  }
}
</script>

<style lang="scss" scoped>
.el-data-table ::v-deep .el-table {
  .table {
    margin-top: 15px;
  }

  .el-table__row {
    &.selected-row {
      background-color: #f5f7fa;
    }

    & > td {
      line-height: 1.5;
      padding: 6px 0;
      font-size: 13px;
      border-right: none;

      * {
        vertical-align: middle;
      }

      .el-checkbox {
        vertical-align: super;
      }

      & > div > span {
        text-overflow: ellipsis;
        overflow: hidden;
        white-space: nowrap;
      }
    }
  }

  .el-table__header > thead > tr > th {
    padding: 6px 0;
    background-color: #ffffff;
    font-size: 13px;
    line-height: 1.5;
    border-right: none;

    .cell {
      white-space: nowrap !important;
      overflow: hidden;
      text-overflow: ellipsis;

      &:hover {
        border-right: 2px solid #EBEEF5;
      }
    }
  }
}

.el-data-table ::v-deep .el-table .el-table__header > thead > tr .is-sortable {
  padding: 5px 0;

  .cell {
    padding-top: 3px !important;
  }
}
</style>
